﻿<?php
/**
 * Classe Db da tabela TB_TIPO_UNIDADE_SAUDE
 * 
 * @author			Mário R. Castro
 * @copyright		Voitech Sistema
 * @package			SEMAS
 * @subpackage		semas.application.models.Db
 * @version			1.0
*/
class App_Model_Db_TipoUnidadeSaude extends Voitech_Db{

	protected $_name 		= 'tb_tipo_unidade_saude';
    protected $_primary 	= 'co_tipo_unidade_saude';
	
	static private $instancia;

	/**
	 * @return App_Model_Db_TipoUnidadeSaude
	 */
	static public function build() {
		if( !isset( self::$instancia ) ) {
			$classe = __CLASS__;
			self::$instancia = new $classe();
		}
		return self::$instancia;
	}
	
	
	public function listarTodos(Voitech_TO $obTO=null){
            $obSelect = $this->getAdapter()->select()
			            				   ->from(array('tb_tipo_unidade_saude'=>'tb_tipo_unidade_saude'),
			            				 		   array(
			            				 		   			'*',
			            				 		   			'fl_excluir' => '(CASE 
																			    WHEN (SELECT count(*) FROM tb_unidade_saude WHERE tb_unidade_saude.co_tipo_unidade_saude = tb_tipo_unidade_saude.co_tipo_unidade_saude) > 0 THEN
																			    	\'N\'
																			    ELSE
																			    	\'S\'
																		  END)'
			            				 		   		));

            if( !empty( $obTO->co_tipo_unidade_saude ) ) {
                $obSelect->where('co_tipo_unidade_saude =?', $obTO->co_tipo_unidade_saude);
            }
            if( !empty( $obTO->no_tipo_unidade_saude ) ) {
                $obSelect->where('no_tipo_unidade_saude like ?', "%".$obTO->no_tipo_unidade_saude."%");
            }
            if( !empty( $obTO->st_status ) ) {
                $obSelect->where('st_status =?', $obTO->st_status);
            }
            return $this->getAdapter()->fetchAll($obSelect);			   						   
	}
		
}